## 第2章



ここでは、米国 Xilinx 社の FPGA のうち、Virtex-4/5 と Spartan-3/E/A/AN/A DSP におけるコンフィグレーション について解説する. 特に、専用コンフィグレーション ROM を 使う際に用いるマスタ・シリアル・モードについて詳しく扱う. また、コンフィグレーションが正常に動作しないといった トラブル発生時の解決法を、症状別に説明する. (編集部)

SRAMベースの FPGA( Field Programmable Gate Array)では,電源投入後にユーザ回路を FPGAへ書き込む,コンフィグレーションと呼ばれる作業が必要です. SRAMベースの FPGA を使用するすべてのユーザがコンフィグレーションを行う必要がありますが,基板上の構成や実行されているプロセスについてはあまり気にせず使っている方が多いのではないでしょうか. どんなに素晴らしい回路設計を行ってもコンフィグレーションがうまくいかないと FPGA は動作しません. FPGA を使うに当たって,ユーザにとっては重要な項目であると思います.

本稿では、米国 Xilinx 社の FPGA を対象としてコンフィグレーションに関する動作説明とトラブル発生時の対策について説明します。

### 1. さまざまなコンフィグレーション・ モード

Xilinx 社の FPGA である Virtex-4/5 と Spartan-3 Generation( Spartan-3/3E/3A/3AN/3A DSPの総称 )ファ ミリでサポートしているコンフィグレーション・モードを 表1に示します.

#### ● 3本のピンでモードを指定する

FPGA に電源が投入されると, FPGA が持つ3本のモード・ピン( M2, M1, M0)に入力されている論理値によってコンフィグレーションを行う方法( コンフィグレーション・モード)が決まります.

マスタ・シリアルとスレーブ・シリアル, JTAGの三つのモードの設定値は、すべてのファミリで共通です。

コンフィグレーション・モードは,以下のように分類できます.

- マスタとスレーブのモード
- シリアルとパラレルのモード
- JTAGモード
- 汎用フラッシュ・メモリ

#### ● マスタとスレーブ

マスタ・モードは, コンフィグレーション・データ(ビットストリームと呼ぶ)を受け取るタイミングを自ら生成します. コンフィグレーションに必要なクロックを FPGA が出力します.

スレーブ・モードは,クロックとコンフィグレーション・データの両方を外部からもらいます.

#### ● シリアルとパラレル

シリアル・モードは,コンフィグレーション・データを 1ビットずつ受信します.

KeyWord

FPGA, Virtex 4/5, Spartan-3 Generation, コンフィグレーション, JTAG, SPI, BPI, マスタ・シリアル・モード

### FPGAを動かすための 基礎知識



#### 表1 コンフィグレーション・モード

| モード・ピン<br>( M2,M1,M0 ) | Virtex-5                                    | Virtex-4                   | Spartan-3A<br>/3AN/3A DSP             | Spartan-3E               | Spartan-3        |
|------------------------|---------------------------------------------|----------------------------|---------------------------------------|--------------------------|------------------|
| 0 0 0                  | マスタ・シリアル                                    |                            |                                       |                          |                  |
| 0 0 1                  | マスタSPI                                      | スレーブ・セレクト・<br>マップ (32 ビット) | マスタSPI                                |                          | -                |
| 0 1 0                  | マスタBPI( Up )<br>(8 ビットまたは 16 ビット)           | -                          | マスターBPI( Up )<br>(8 ビット)              |                          | -                |
| 0 1 1                  | マスタBPI( Down )<br>(8 ビットまたは 16 ビット)         | マスタ・セレクト<br>・マップ           | 内部SPI <sup>1</sup><br>(Spartan-3ANのみ) | マスタBPI( Down )<br>(8ビット) | マスタ・セレクト<br>・マップ |
| 1 0 0                  | マスタ・セレクト・マップ (8ビット,16ビット自動認識)               | -                          | -                                     | -                        | -                |
| 1 0 1                  | JTAG                                        |                            |                                       |                          |                  |
| 1 1 0                  | スレーブ・セレクト・マップ<br>(8ビット,16ビット,32ビット<br>自動認識) | スレーブ・セレクト<br>・マップ(8ビット)    | スレーブ・セレクト・マップ                         |                          |                  |
| 111                    | スレーブ・シリアル                                   |                            |                                       |                          |                  |

注:BPIモードには,メモリのアドレスをインクリメントしながらデータを読み出すUpモードと,アドレスをデクリメントしながらデータを読み出すDownモードがある.

パラレル・モードは,複数のビットを一つの単位として 受信します.パラレル・モードをセレクト・マップ・モー ドと呼ぶ場合もあります.

セレクト・マップでは,基本的には8ビット単位でコンフィグレーションを行います.Virtex-4とVirtex-5では,さらに16ビット幅と32ビット幅のモードも用意されています.

セレクト・マップでは,コンフィグレーションのために 多くのピンを使用します.FPGAにとって必要なデータ量は,コンフィグレーションのモードで変わりません.つまり,データをパラレルで受信すれば,シリアルで受信するよりもコンフィグレーション時間が短くて済みます.

Virtex-4のセレクト・マップでは,ビット幅ごとにモード・ピンの設定値が規定されています.Virtex-5では,ビットストリームの先頭にバス幅検出用のデータが含まれており,データ・バスのどのバイト・レーンにバス幅検出用データが出現するかを自動的に判別することでコンフィグレーション時のビット幅が決まります.

#### ● JTAGモード

JTAGモードは、パソコンからダウンロード・ケーブルを使用してFPGAを直接コンフィグレーションする場合に使うことが多い方式です.Xilinx 社では、S<sub>YSTEM</sub> ACE という FPGA のJTAGを使用しています.S<sub>YSTEM</sub> ACE は、Compact Flash からコンフィグレーションするシステムです.また、ChipScope のようなオンチップ・デバッグ・

ツールでは, JTAG 経由で FPGA 内部へアクセスします. デバッグの用途などを考えると, FPGA のJTAG ピンへ アクセスできるように基板を設計しておくことをお勧めし ます.

#### ● 汎用フラッシュ・メモリからのコンフィグレーション

Spartan-3E 以降のファミリ( Spartan-3E/3A/3AN/3A DSP, Virtex-5)では、汎用フラッシュ・メモリから直接コンフィグレーションできるようになりました。SPI( Serial Peripheral Interface )のシリアル・タイプと BPI( Byte Peripheral Interface )のパラレル・フラッシュの両方に対応しています。

Spartan-3までは,汎用フラッシュ・メモリからコンフィグレーションする場合,フラッシュ・メモリと FPGA の間に制御用の回路(CPLDを使うことが多い)を配置する必要がありました.これに対し,Spartan-3E以降では,データシートなどに記載されているフラッシュ・メモリであればFPGA と直接接続できます.

Spartan-3A 系の三つのファミリ( Spartan-3A/3AN/3A DSP )では,基本的に同じコンフィグレーション・モードが使用可能です.Spartan-3ANにのみ,内部SPIモードがあります.

Spartan-3ANは, SRAMベースの FPGA とコンフィグレーション用のフラッシュ・メモリを1チップにしたマルチチップ・モジュールです.内蔵のコンフィグレーション用フラッシュ・メモリを使うときには,内部 SPI モードを

用います.この際, $V_{CCAUX}$ 電源に3.3Vが必要である点に注意が必要です.

#### ● 汎用フラッシュ・メモリを使用したマルチブート

汎用フラッシュ・メモリをコンフィグレーション・データの保存場所として使用するメリットの一つとして,保存可能なデータ容量が大きい点が挙げられます.あらかじめ複数の回路(コンフィグレーション・データ)を用意しておき,動作状態に合わせて切り替えながら使うようなアプリケーションや,フィールドでアップデートを行いたい場合などに活用できます.

汎用フラッシュ・メモリからのコンフィグレーションを サポートしている Spartan-3E 以降のファミリでは, あらか じめ複数のコンフィグレーション・データを使用すること を考慮した, マルチブート構成をとることができます.

マルチブートに関する特徴を**表**2に,使用するマクロを**図**1に示します.これらのマクロをユーザ回路の一部として組み込んでおき,制御することで,マルチブートが可能になります.

Spartan-3Eでは、一つのフラッシュ・メモリにコンフィグレーション・データを2個までしか搭載できません。しかしコンフィグレーション・データを切り替えるトリガのかけ方は簡単です。ユーザ回路の一部にSTARTUP

SPARTAN3E セルを組み込んでおき,その MBT( Multi Boot Triger )入力ピンに300ns 以上の" L "パルスを入れることで再コンフィグレーションがかかります.

Spartan-3A と Virtex-5では,ユーザ回路の一部にICAP (Internal Configuration Access Port)セルを組み込み,入力データ用バスから一連のコンフィグレーション・コマンドを入力する必要があります。シーケンスを与える必要がある点で,若干手順が複雑ですが,リブート先の読み出しアドレスを任意に選択できるなど自由度があります。コンフィグレーション専用のウォッチドッグ・タイマが搭載されている Spartan-3A では,フラッシュ・メモリへの書き込みが不完全であった場合などを想定して,マルチブート・トリガ後の規定時間内に期待するビットストリームが受信できない場合に,再度デフォルトのアドレスのデータでコンフィグレーションし直すことが自動でできます。

#### ● コンフィグレーション・データのファイル形式

コンフィグレーションで使用する代表的なファイル形式 を**表**3に示します.

専用コンフィグレーション ROM に書き込むための mcs ファイルと, JTAG で FPGA へ直接ダウンロードする際に 使用する bit ファイルが最もよく使われています.

最近,組み込みシステムで,外部からコンフィグレー

表2 マルチプートの対応

|               | Spartan-3E        | Spartan-3A    | Virtex-5      |
|---------------|-------------------|---------------|---------------|
| マルチブート手順の複雑さ  | 簡単                | 若干複雑          | 若干複雑          |
| BPIによるマルチブート  | 可注1               | 可注2           | 可注2           |
| SPI によるマルチブート | 不可                | 可             | 可             |
| マルチブートのトリガ方法  | STARTUPプリミティブの    | ICAPプリミティブにリブ | ICAPプリミティブにリブ |
| マルテラーFODF5カカ法 | MBT ピンに' L 'パルス入力 | ート・シーケンスを入力   | ート・シーケンスを入力   |
| 使用可能なビット・データ数 | 2                 | フラッシュのサイズによる  | フラッシュのサイズによる  |
| ウォッチドッグ・タイマ   | なし                | あり            | あり            |

注1 リプート時はモード・ピンの設定と反対方向から再コンフィグレーションされる. 例えばBPI-UPモードに基板上設定されている場合,再コンフィグはBPI-DOWNで行われる.

注2 マルチブート時の開始アドレスはリブート前のユーザ回路が指定する.



図1 マルチプートに使用する マクロ

### FPGAを動かすための 基礎知識



ションROMのデータを書き換え,リモート・アップデートを行いたいといった要望を聞くことがあります.そのような場合にはXSVFやACEファイルが活用できます.

### 2. マスタ・シリアル・モードを 使いこなす

FPGA は、さまざまなコンフィグレーション・モードを持ちますが、最も基本となるのはマスタ・シリアル・モードといえます。ここでは、マスタ・シリアル・モードにおけるコンフィグレーション回路/基板設計上の注意点について説明します。

Spartan-3A をマスタ・シリアル・モードで専用コンフィ

グレーションROM( Platform Flash PROM )からコンフィグレーションする際のコンフィグレーション回路を**図**2に示します.

Spartan-3A の電源系は $V_{CCINT}$ ,  $V_{CCAUX}$ ,  $V_{CCO}$ (4バンク分)の3系統ありますが,  $V_{CCAUX}$ は2.5Vまたは3.3Vのどちらかから選択できるようになりました.  $\mathbf{Z}$ 2は $V_{CCAUX}$ を2.5Vとした場合の接続で,この場合 Spartan-3E でも同様の接続が可能です.

#### ● 電源

プログラム・ピン ,  $\mathsf{JTAG}$  ピン ,  $\mathsf{DONE}$  ピンは $V_{CCAUX}$  電源系に含まれています . このため , これらのインターフェース用の $\mathsf{I/O}$  電圧は $V_{CCAUX}$  の電圧に合わせておく必要

表3 コンフィグレーションで使用する 代表的なファイル

| 拡張子   | 説 明                                                             |
|-------|-----------------------------------------------------------------|
| .BIT  | iMPACTでFPGAへJTAG経由でダウンロードする際に使用する.バイナリ・ファイルでコンフィグレー             |
|       | ション・データのほかにヘッダ情報を含む.                                            |
|       | │ .BIT ファイルからコンフィグレーション・データ部分のみを取り出したバイナリ・ファイル . マイクロプ │        |
| .BIN  | ロセッサなどからユーザ独自のコンフィグレーション方法を行う際に利用可能.Bitgen のオプション設定             |
|       | により生成する.                                                        |
|       | コンフィグレーション ROM 書き込み用に使用するテキスト形式ファイル.コンフィグレーション・データ              |
| .MCS  | のほかに,アドレス,チェック・サム情報を含む.iMPACT で専用コンフィグレーション ROM( Platform       |
|       | Flash PROM)をターゲットに生成した場合,自動的にビット・スワップが行われている.SPI フラッシュ          |
|       | ・メモリをターゲットにした場合はビット・スワップは行われない.                                 |
| HEX   | コンフィグレーション・データのみを含むテキスト形式ファイル.ユーザ独自のコンフィグレーション方                 |
| .HEX  | 法を行う際に利用する.iMPACTで生成する際にビット・スワップの有無はユーザが選択可能.                   |
|       | Xilinx Serial Vector Formatの略.JTAGの操作手順記述には,一般的には,SVFファイルが使用される |
| .XSVF | が,テキスト形式のSVFのファイル・サイズを縮小する目的で Xilinx 社が独自に定義したバイナリ・ファ           |
|       | イルのフォーマット . アプリケーション・ノート Xapp058, Xapp503 にフォーマットの記載があり , 特に    |
|       | 組み込みシステムでコンフィグレーション ROM の書き換えを行うような場合に使用可能.                     |
| .ACE  | 主にSystem ACE コントローラを使用したCompactFlash からJTAG でコンフィグレーションするための    |
|       | データ・フォーマット.Xapp424に ACE ファイルを仕様したJT AG コントローラの記載がある.            |



図2 マスタ・シリアル・モードの回 路例

Spartan-3A において  $V_{CCAUX}=2.5$ V の場合を示す.図には記載していないが,パワー・マネージメント機能のサスペンド・モードを使用しない場合は,SUSPEND ピンをGND に接続する.

があります.また,JTAG用ピン・ヘッダ部にある電圧参照用の $V_{REF}$ 電圧と,DONE ピンのプルアップ電圧も $V_{CCAUX}$ に合わせてください.

Spartan-3AのパワーONリセットは、VCCINT、VCCAUX、VCCO-2の電圧が規定値まで上昇すると解除されます.パワーONリセットに使用されるI/O電源のバンクは、デバイス・ファミリにより異なります.どのFPGAでもパワーONリセットに使用される電源は規定の時間内に単調増加で上昇させる必要があります.電源投入直後はFPGAや周辺チップ用のバイパス・コンデンサが充電されたり、FPGA自体パワーONに一定量の電流が必要となるため、完全な単調増加が難しい場合もありますが、図3のようなイメージで電源投入のOK/NGを判断できます.図3(a)は理想的な波形で、規定時間内に推奨電圧まで滑らかに電源が上昇しています.図3(b)は途中で上昇が緩やかになっていますがドロップするまでは至っていないためOKと判断します.図3(c)はドロップが発生しているため修正が必要です.

#### ● プログラム・ピン(PROG\_B)

プログラム・ピンに" L "レベルを入力することでコンフィグレーション・メモリをクリアします.

電源投入時の電圧が上昇している最中は、プログラム・

ピンを"L"固定にしてコンフィグレーションが始まらないようにし、電源が安定した後"H"へ遷移させることで安定したコンフィグレーションを行えます.このため、プログラム・ピンの制御には電源監視ICやリセットICを使用することを推奨しています.

なお , プログラム・ピンには $V_{CCAUX}$ 電源への内部プルアップがあります . ピン自体が未接続や基板上で単純なプルアップになっていても特に問題ありませんが , できるだけプログラム・ピンを制御可能なように構成します .

#### ● INIT\_Bピン

INIT\_B ピンはオープン・ドレインです. コンフィグレーション・メモリのクリア中は FPGA が L "ヘドライブし, 完了するとハイ・インピーダンス( Hi-Z )になります. 基板上には4.7k のプルアップを付けておくことで, メモリ・クリア完了後外部からば H "出力が見えるようになります.

"H"が確認されると次のプロセスへ移行しますが,この 段階でコンフィグレーションの開始を遅らせたい場合は, 外部から"L"にドライブできます.プルアップ抵抗は1k 程度の小さな値でも問題ありませんが,4.7k を一般的に は勧めています.

INIT\_B ピンを専用コンフィグレーション ROM のアクティブ L "のリセット・ピンに接続することで, FPGA がメモリ・クリア中は専用コンフィグレーション ROM もリセット状態になります. FPGA のメモリ・クリアが終了すると専用コンフィグレーション ROM もリセット解除される動作となります.



図3 電源の立ち上がり ドロップが発生している場合は修正が必要.



(b) 許容範囲内の電源立ち上がり



(c)修正が必要な電源立ち上がり

### FPGAを動かすための 基礎知識



#### ● モード・ピン(M[2:0])

モード・ピンはすべてのデバイスで3ピンあり,コンフィグレーション・モードを決めるピンです.

INIT\_Bの立ち上がリエッジで値が読み取られ,コンフィグレーション・モードが決定します.INIT\_Bの立ち上がり時にはモード・ピンのレベルを完全に確定しておきたいため,GNDまたはVcco\_2の電圧レベルに直接,接続します.デバッグ時などは,例えばJTAGモードに変更したい場合などを想定して,0 抵抗を介して接続することをお勧めします.ただし,Spartan-3E/3Aにおいて,コンフィグレーション後にモード・ピンをユーザI/Oとして使用する場合は、0 で接続することができないので注意が必要です.

#### ● PUDC Bピン

PUDC\_BはSpartan-3AではPullup During Configuration という意味です.ほかのファミリではHSWAP\_ENやHSWAPという名称が使われています.呼び方が違っていても機能は変わりません.

このピンはコンフィグレーション中にユーザI/Oに内部プルアップを適用するか,ハイ・インピーダンスのままにするかを選択するピンです.コンフィグレーション中は値を固定しておく必要があります.

モード・ピンと同様に,ユーザI/Oとして使用しない場合は0 抵抗を介してGNDや電源に接続しておくことをお勧めします.

**図**2の例では、GNDへ接続しています.こうすることで、コンフィグレーション中に $V_{CCO}$ への内部プルアップが働いて、ユーザI/O は外部からは"H"レベルに見えます.

PUDC\_B で設定できるコンフィグレーション中の I/O ピンの状態は,ハイ・インピーダンスか内部プルアップによる"H"レベルのどちらかです.しかし,どうしてもコン

フィグレーション中に" L "レベルをユーザ I/O に出した II 場合もあるでしょう.このような場合は, PUDC\_B を" L "にして I/O を" H "レベルにしてインバータを外付けするか,基板上にプルダウン抵抗を配置することになります. PUDC\_B が" H "でユーザ I/O がハイ・インピーダンスの場合はプルダウン抵抗値の選択にあまり気を使う必要はありません.PUDC\_B が" L "で内部プルアップが有効になっている場合は,内部抵抗に打ち勝つようにかなり小さめの値の外部プルダウン抵抗を選択する必要があります.

#### ● CCLKピン

CCLKは、コンフィグレーション用のクロック・ピンです.INIT\_Bの立ち上がりエッジでモード・ピンがサンプルされ、マスタ・モードであることが認識されるとFPGAはCCLKのトグルを始めます.

Spartan-3A 以外の FPGA ファミリでは,マスタ・モード FPGA の CCLK は双方向ピンとして構成されます.このため,基板上のノイズがマスタの FPGA 自体のコンフィグレーションにも影響します. Spartan-3A ではこの点が改善され,マスタ・モード時は純粋な出力ピンとして CCLK が構成されます.

CCLKピンは,シリーズ抵抗をピンの直近に配置するか, テブナン終端を使用するなどしてクロックの立ち上がリ エッジ部にノイズが乗らないように注意する必要がありま す.50 特性インピーダンスの伝送路を想定した場合,シ リーズ抵抗なら20 ~30 程度が目安となります.

ユーザ・ガイド(1)には**図**4のようにCCLKピンにテブナン終端の例が紹介されています.CCLKがほかのFPGAやコンフィグレーションROMに分岐する場合は,スター型の配線ではなくマルチドロップにして,さらにスタブを12.5mm以内に抑える必要があります.

#### **図**4 CCLK **信号の注意**

シリーズ抵抗をピンの直近に配置するか,テブナン終端を使用するなどしてクロックの立ち上りエッジ部にノイズが乗らないように注意する必要がある.CCLKがほかのFPGAやコンフィグレーションROMに分岐する場合は,スター型の配線ではなくマルチドロップにして,さらにスタブを12.5mm以内に抑える必要がある.



#### ● DONEピン

DONE ピンは, コンフィグレーション中は FPGA が L "をドライブし, 完了するとハイ・インピーダンスになるオープン・ドレインのピンです.

DONE ピンには330 のプルアップ抵抗を*VcCAUX*電圧のレベルに付けてください.330 はかなり小さい値に思えるかもしれませんが, CCLKの1サイクル以内に確実にDONE ピンを"L"から"H"へ遷移させる必要があることと,コンフィグレーション中の"L"ドライブ中のシンク電流値の関係で330 を推奨しています.

DONE ピンと専用コンフィグレーション ROM の CE ピンを接続しておくことで,コンフィグレーション完了後 DONE が H "になるのと同時に専用コンフィグレーション ROM が切り離されます.

#### ● JTAGピン(TCK, TMS, TDI, TDO)

JTAG ピンは $V_{CCAUX}$ 電源系を使用しています.このため, $V_{CCAUX}$ が2.5V のときは基本的にはJTAGインターフェースの電圧は2.5V レベルで行う必要があります. $V_{CCAUX}$ が2.5V のときに3.3V のJTAGチェーンを組みたい場合は,TCK,TMS,TDIの各入力ピンに直列抵抗を入れて,電流制限を行う必要があります.

コンフィグレーション後のJTAGピンは,FPGA開発ツールISEのデフォルト設定では内部プルアップになります.念のため基板上でもプルアップすることをお勧めします.プルアップ抵抗値はさほど気にする必要はありませんが,一般的には4.7k 程度です.

#### ● DOUTピン

図2には記載していませんが,スレーブ・モードのFPGAをカスケード接続する際に,下流のスレーブ・デバイスへコンフィグレーション・データを出力するピンです.

### 3. トラブル発生時のFAQ

コンフィグレーション回路は,これまで説明してきた注意 点を守って設計されていれば,トラブルの原因になることは ほとんどありません.しかし,コストを抑えるなどの理由で 指定通りの部品を搭載できないような場合もあるでしょう.

コンフィグレーションが成功しないといったトラブルが 発生したときは,まずオシロスコープを使用して以下の信 号を確認します( pp.83-85 のコラム「マスタ・シリアル・ モードのコンフィグレーション・フロー」を参照).

- 電源 (V<sub>CCINT</sub>, V<sub>CCAUX</sub>, V<sub>CCO</sub>)
- プログラム・ピン
- INIT B
- DONE
- CCLK
- データ入力ピン( DIN )

特に FPGA がうんともすんともいわないような場合は ,電源のランプアップが**図**3の判断基準に照らし合わせて問題ないかどうかと , プログラム・ピンが H "に遷移しているかどうかを最初に確認します .

電源とプログラム・ピンの動作に問題がなければ何かしらコンフィグレーション回路は動いているはずです.筆者の経験では基本的にCCLKがきれいに出ているのにコンフィグレーションがうまくいかないといったトラブルのほとんどはケアレス・ミスが原因です.

#### ● マスタ・モード FPGA の CCLK が出ない

マスタ・モードの FPGA は , 電源を投入し , コンフィグレーションを行う準備が整うと , CCLKをトグルし始めます . CCLK がトグルし始めない症状が出ている場合は , モード・ピンがマスタ・モードになっているかを確認してください . モード・ピンは INIT\_B の立ち上がりエッジで読み取られるので , INIT\_B が L "から" H "へ遷移していることも確認します .

外部から INIT\_Bを"L"に固定しているような場合や, INIT\_Bのプルアップ抵抗を付け忘れている場合には, CCLK は出力されません.また, CCLK にダンピング抵抗を付けている場合は,抵抗自体が壊れていないかも念のため確認します.

#### ● CCLKのトグルが止まらない場合

マスタの FPGA が CCLK を出力していて,コンフィグレーション ROM からも何かしらのデータが出ているのに,いつまでたってもコンフィグレーションが終了しない場合があります.DONE = "L",INIT\_B = "H"のままとなり,あたかもコンフィグレーションをずっと行っているかの状態に見えます.

原因としては,コンフィグレーション・データの最初に入っている同期ワードをFPGAが正常に受信できていない

### FPGAを動かすための 基礎知識



ことが考えられます. CCLKの立ち上がリエッジにノイズが 乗って,同期ワードのビットがずれてしまうと,以降のデータをすべて読み飛ばすため,このような症状になります.

また,同期ワードの受信に成功していても,CCLKにダブル・エッジなどが発生していると,コンフィグレーション・フレームをずれた状態で認識してしまい,CRCチェック・コマンドを正常に受信できずにこの状態になる場合があります。

同期ワードの受信が成功しているかどうかを調べるには、 CCLKの周波数をオシロスコープで測定するのが簡単です。 同期ワードの受信に成功していれば、CCLKの周波数は ユーザがISEで選択した周波数に遷移しているはずです.

同期ワードやCRCコマンドの受信に失敗する大きな原因は,上述したようにCCLKの波形が問題となる場合がほとんどです.このため,ダンピング抵抗をCCLKピンの近くに配置して波形を滑らかにしたり,FPGAと専用コンフィグレーションROMをできるだけ近くに配置するなどして対策します.CCLKはデフォルトの設定ではたかだか数MHzと低速ですが,スルー・レートは比較的高速であることと,多くのFPGAファミリにおいて,マスタ・モードのCCLKが双方向で構成されているために波形品質に注意する必要があります.

### コラム マスタ・シリアル・モードのコンフィグレーション・フロー

電源投入からユーザ回路の動作が始まるまでのフローを**図**A-1に示します.

#### ● 電源投入からモード・ピンのサンプルまで

電源投入が完了し,プログラム・ピンが"L"の間はFPGA がコンフィグレーション・メモリの初期化ステートにとどまります.メモリ初期化中はINIT\_BをFPGA が"L"にドライブします.プログラム・

ピンが" H"になり初期化が完了すると, INIT\_B は外付けのプルアップにより" H"レベルに遷移し, INIT\_B の立ち上がりエッジでモード・ピンの値を読み出し, コンフィグレーション・モードが決定します.

#### ● 同期化からCRC チェックまで

INIT\_Bの立ち上りエッジでモード・ピンをサンプルした結果,マスタ・モードのいずれか(シリアル,パラレル,SPIなど)である場



図A-1 コンフィグレーション・フロー

#### ● DONEは"L"のまま、INIT\_Bも"L"になった場合

CCLK が停止し, DONE とINIT\_B が L "の場合, CRC エラーまたはID コード・エラーが原因でコンフィグレーションが失敗したことを表しています.

FPGA 開発ツールの ISE で指定したターゲット・デバイスが,実際に基板上にある FPGA の型名と合っているかを再確認します. FPGA の型名が正しければ, CCLK の波形を確認してください.

#### ● DONE は"H" だが何か動きがおかしい

DONE が"H"になっているので,基本的にコンフィグ

レーションは完了しています.

しかし,この場合でも少々注意しておきたい点があります.DONEの立ち上がり遷移は,1 CCLK サイクル以内に行われなくてはなりません.外付けプルアップ抵抗が非常に大きな値のものを使用している場合などで1サイクル以内に遷移できない場合,不安定な動作になる場合があるようです.

また,外部のプロセッサなどからスレーブ・モードでコンフィグレーションさせているような場合は,DONEが "H"になったからといって,すぐにCCLKの供給を止めてしまうとスタートアップ・シーケンスを完了できない場合

### コラム マスタ・シリアル・モードのコンフィグレーション・フロー(つづき)

合は, CCLK ピンからクロックを出力し始めます. CCLK のトグル 周波数は,デバイスごとにデフォルト値が決まっており,トグル開 始時はこの周波数で動き出します.

クロックがトグルし始めることでPROMからデータが出力し始めます.Spartan-3 Generationファミリの場合は,ダミー・データ(FFh)がしばらく続いた後,表A-1に示す同期ワード(シンク・ワードともいう)を正常に受信するとコンフィグレーション・データであることが認識され,それ以降の処理を継続します.同期ワードが正常に認識されない場合は,コンフィグレーションROMから後続のデータが読み出されても,FPGAはその部分をコンフィグレーション・データとは認識せず,すべて無視します.このため,同期ワードを認識することは非常に重要なイベントです.

シリアル・モードでコンフィグレーションする場合, bit ファイルのバイナリ・イメージで見るとMSBを先に読み, LSBを最後に読み込む必要があります. Xilinx 社の専用コンフィグレーション ROM (Platform Flash PROM など)は LSBを最初に出力する仕様になっています. このため, 表A-2に示すビット・スワップ(バイト・スワップと呼ぶこともある)により, MSBから LSBまでの8ビットを入れ替える必要があります. ただし, iMPACTを使用して Xilinx のシリアル・コンフィグレーション ROM をターゲットに bit ファイルから MCS ファイルを生成する場合は, ツールが自動的にビット・スワップを行ってくれます. SPI フラッシュのような MSB を最初に出

力するタイプのメモリ素子の場合は、ビット・スワップが行われないようにする必要がありますが、iMPACTでSPIフラッシュをターゲットとして MCS を生成する場合はビット・スワップは行わないようになっています。

どちらにしても、iMPACTで正しくターゲット・デバイスを選択していれば、ビット・スワップについて何も気にする必要はありません.なお、ビット・スワップについて明示的に選択したい場合は、HEXファイルを選択することになります.

同期ワードの認識が成功した後,IDコード・チェック用のデータを受信し,実際のデバイスがターゲットとして正しいか確認されます.このため,ISEでマッピングした際のターゲット・デバイスと異なるデバイスにコンフィグレーションしようとすると,IDコード・

表 A-1 同期ワードのパターン

| デバイス・ファミリ                                                  | 同期ワードのパターン |  |
|------------------------------------------------------------|------------|--|
| Spartan-3A/3AN/3A DSP                                      | A A 99     |  |
| その他の Virtex アーキテクチャ・デバイス<br>(Spartan-3/3E, Virtex-5/4 etc) | A A 995566 |  |

- \* 16 進数表示でビット・スワップを行っていない場合のデータ・パターンで表してある。
- \* シリアルでコンフィグレーションする場合は,MSB側のビットから処理する.例えばAA99の場合はA(1 0 1 0) A(1 0 1 0) 9(1 0 0 1)のビットの順番で処理する.

表 A-2 ビット・スワップの例

|                      | 16進数表現 | AA       | 99       | 55       | 66       |
|----------------------|--------|----------|----------|----------|----------|
| ビット・スワップ<br>していないデータ | 2進数表現  | 10101010 | 10011001 | 01010101 | 01100110 |
| ビット・スワップ<br>後のデータ    | 2進数表現  | 01010101 | 10011001 | 10101010 | 01100110 |
| <b>反</b> ())         | 16進数表現 | 55       | 99       | AA       | 66       |

<sup>\*</sup> ビット・スワップするとAAは55になる

### FPGA表動かずための 基礎知識



があります、独自のコンフィグレーション・インターフェー スで処理する場合は, MCSファイルや HEX ファイルの データをすべて FPGA へ送り終わった後に, DONE ピンの 状態を確認してOK/NGの判断をするようにしてください. データ・ファイルの最後の部分にはダミー・データが含ま れており、データをすべて送り出していればスタートアッ プ・シーケンスを完了するのに十分な時間を取れるように なっています.

#### ● コンフィグレーション完了直後に変なパルスが出る

以前、「コンフィグレーション後は"H"を維持するはず

の信号が、DONE が上がった直後くらいに一瞬"L"が出て しまう」との問い合わせを受けたことがありました.

問題となった出力信号は、リセット系の信号を作ってい るI/Oでした.このため,パルスを出力すると外部のリ セット信号をアサートしてしまい、単純な回路構成ながら かなり問題視された記憶があります.

コンフィグレーションの最後の工程であるスタートアッ プ・シーケンスにおいて, FPGA 設計ツール ISE のデフォ ルトの設定では, DONE GTS GWE の順番でイベント が発生します.DONEを開放して外部にコンフィグレー ションの完了を通知した後に、出力ピンがドライブを開始

ありません.

IDチェックも成功すると、ISEのGenerate Programming Fileの プロパティで設定した CCLK の速度へ遷移します. デバッグ時には CCLKの周波数がデフォルト周波数から変化したかどうかを確認す れば,この段階まで処理が進んだかどうかチェックできます.

その後はコンフィグレーション・データを読み込み続け, CRC チェックのコマンドとCRC の期待値を FPGA に送り込み, FPGA 内 部でCRCの計算を行い、期待値と一致していれば、最終段階のス タートアップ・シーケンスへと進みます.

#### ● スタートアップ・シーケンス

スタートアップ・シーケンスは、コンフィグレーション動作から ユーザ回路動作へ移行する8フェーズのシーケンスです.このシー ケンスの中で行われる主な処理は, DONE ピンの開放("L"のドライ ブをやめる), ユーザ回路の出力ピンのドライブ開始, フリップフ ロップやRAM といった同期エレメントへの書き込みの開始などで す.デフォルトの設定では図A-2のタイミングで各イベントが発生 します.また,同期エレメントの初期化に使用されるGSR(Global Set Reset )のアサートやDCM のロックの開始は,スタートアップ・ シーケンスの最初のフェーズで行われます.

スタートアップ・シーケンスで使用するクロックは ISE の中で図

チェックの段階で中断するので、デバイスが破損するようなことは A-3のプロパティ設定ウィンドウで、CCLK、JTAGクロック、ユー ザ・クロックの三つの中から選択します. 基本的にJTAGからコン フィグレーションするときはJTAGクロックを選択し、それ以外の ときはCCLKを選択します.

> スタートアップ・クロックの選択を間違えると、スタートアップ・ シーケンスが実行できないため、コンフィグレーションも完了でき ません.しかし,iMPACTでコンフィグレーションROMやFPGA へ書き込む際に,一般的に使用されるクロック系と異なるものを選 択している場合は, Warning を表示してクロック系の変更をしてく れます.

> スタートアップ・シーケンスが最後まで行われることで、ユーザ 回路動作への移行が完了となります.

#### ● ユーザ回路の動作開始

図A-1に示す信号の中で,ユーザI/Oとして使用可能なものがい くつかあります.それらをユーザ1/0として使用していない場合は, 通常の未使用 I/O ピンの処理が行われ,デフォルトでは内部プルダ ウンが働きます.このため INIT B ピンのような基板上にプルアッ プが付いているもので,コンフィグレーション後にユーザ1/0とし ては使用しない場合は,個別にピンをハイ・インピーダンス状態に するなどの処理をユーザ回路の一部で行うと、リーク電流を抑えら れます.



図A-2 Spartan-3 Generation のデフォルト・スタートアップ・シーケンス



図A-3 スタートアップ・シーケンスのオプション設定

し、さらにその後に内部のフリップフロップへの書き込みが行えるようになります.フリップフロップの初期化はスタートアップ・シーケンスの先頭ですでに行われており、このとき問題となったフリップフロップは'0'に初期化されていました.フリップフロップへの入力データは1で、クロックも来ているにもかかわらずGWEのアサートがGTSより後になっているため、一瞬だけ初期値の'0'が外部に出力されることが原因でした.

GWE がGTSより前に発生するようにスタートアップ・シーケンスを変更することで,コンフィグレーション直後に"L"パルスが出ることはなくなりました.念のため記しておきますが,これはツールや基板の不具合ではなく,すべて既知の動作でした.

#### ● コンフィグレーション後にINIT\_Bが"L"になる

DONE が" H "になった後, INIT\_B が" L "になってしまう場合があります.

コンフィグレーションが完了(DONE が"H")した後, Spartan-3 GenerationのFPGAでは,INIT\_BピンはユーザI/Oとして使用できるようになります。このときユーザ回路でINIT\_Bピンを使用していない場合は,未使用ピンの扱いとなります。未使用ピンは,FPGA設計ツールISEのデフォルト設定では内部プルダウンです。このため,コンフィグレーション完了後にINIT\_Bが"L"に遷移するの

は,多くのケースでまったく問題ない動作です.

もちろん、未使用ピンの処理を内部プルアップに設定すれば、コンフィグレーション後にINIT\_Bをユーザ回路で使用していない場合に"H"が現れるようになります.

補足すると,INIT\_Bには基板上に4.7k のプルアップ抵抗が付いているので,内部プルダウン抵抗と基板上のプルアップ抵抗がつながることになり,結果としてINIT\_Bは完全にはGNDには落ちません.これでFPGAが破壊に至ることはないのですが,気になるようでしたらユーザ回路でINIT\_Bピンが"H"またはハイ・インピーダンスになるように設計しておくとよいでしょう.

#### 参考・引用\* 文献

- (1) Spartan-3 Generation Configuration User Guide, Xilinx, May 23, 2007.
- (2) Virtex-5 FPGA Configuration User Guide, Xilinx, July 31, 2007.
- (3) Virtex-4 Configration Guide, Xilinx, Aug. 8, 2007.

やすい・けん アヴネット ジャパン(株)

#### <筆者プロフィール> 一

安井 健.2001年9月, アヴネットジャパン(当時メメックジャパン)入社以来, FAEとして活動. それ以前は通信系の電気メーカで電気系 CAD ツールの社内サポートなどを行っていた.

Design Wave Magazine 2007年5月号增刊

好評発売中



### FPGA/PLD 設計スタートアップ 2007/2008 年版

Design Wave Magazine編集部編 B5変型判 256ページ DVD-ROM付き 定価 2,100円(税込)

FPGA やPLDなどのプログラマブル・デバイスをターゲットにした設計をこれから始める方のための入門書です.「Quartus II」や「ISE」などのFPGA/PLD開発ツールの使い方を具体的な手順を示しながら説明しています.

また、「Cyclone/II/III」、「MAX II」「Spartan-3/E/A/AN」などのアーキテクチャを解説します.HDL による論理回路の設計例,周辺回路の設計法などの解説がありますので,FPGA/PLD を活用していくにあたってのハンドブックにもなります.シリアル通信回路,LCD表示回路など,数多くのサンプル回路を紹介しています.付属 DVD-ROM には,「Quartus II Web Edition」と「ISE WebPACK」のほか,記事に関連する設計データを収録しています.

**CQ出版社** 〒170-8461 東京都豊島区巣鴨1-14-2 販売部 ☎ (03)5395-2141 振替 00100-7-10665